草庐IT

C++ 11:std::thread池化?

全部标签

c++ - 我如何使用 11 位数字

我想在我的变量-number中输入一个11位数字,但我认为没有那么多内存。我尝试使用*number和int*number=newint[100],但它不起作用。我还想在我的变量-name中添加姓名和姓氏,但每次我使用空格时,它也会停止工作。我该如何解决这些问题?#include#includeusingnamespacestd;structNOTE{stringname;intnumber;intbirthday[3];};intmain(){//int*tel=newint[100];//int*ptr=newint;NOTEarr[3];cout>arr[i].name;cout>

C++ 11新特性之可变参数模板

概述        随着C++11标准的发布,C++语言获得了许多强大的新特性,其中一项显著提升灵活性和实用性的创新便是可变参数模板。这一特性极大地扩展了模板在处理不定数量类型或值参数时的能力,为开发者提供了更为强大且灵活的泛型编程工具。工作机制        在C++11之前,模板参数的数量必须是固定的。这意味着,对于那些需要处理任意数量参数的情况,程序员不得不采用一些间接手段,比如:重载函数或模板特化。然而,可变参数模板允许编译时传递任意数量的类型或对象到模板中。        学习C++的人应当对printf非常熟悉,printf的一个特点就是它的参数个数是可变的。而在C++11中,则允

c++ - 为什么 std::tr1::shared_ptr<>.reset() 如此昂贵?

分析一些大量使用shared_ptrs的代码,我发现reset()的开销出奇地大。例如:structTest{inti;Test(){this->i=0;}Test(inti){this->i=i;}};...autot=make_shared(1);...t.reset(somePointerToATestObject);跟踪最后一行中的reset()(在VC++2010下),我发现它创建了一个新的引用计数对象。有没有更便宜的方法,重用现有的引用计数并且不打扰堆? 最佳答案 在一般情况下,您不能重用现有的引用计数,因为可能有其他s

c++ - 将 lambda 转换为 std::tr1::function

使用带有tr1服务包和IntelC++编译器11.1.071[IA-32]的visualstudio2008,这与我的其他相关question我正在尝试为c++编写一个功能映射,它的工作方式有点像ruby​​版本strings=[2,4].map{|e|e.to_s}所以我在VlcFunctional命名空间中定义了以下函数templatevectormap(constContainer&container,std::tr1::functionf){vectortransformedValues(container.size());intindex=-1;BOOST_FOREACH(c

c++ - 什么是正确的 std::set_union 代码?

Thissite声称set_union等效于以下代码:templateOutputIteratorset_union(InputIterator1first1,InputIterator1last1,InputIterator2first2,InputIterator2last2,OutputIteratorresult){while(true){if(*first1但这看起来很奇怪:如果其中一个范围为空,会不会崩溃(或导致其他未定义的行为)?这两个if子句不应该在while循环的开头,而不是结尾吗? 最佳答案 我同意它看起来完全坏

c++ - 使用 std::accumulate 计算 vector 元素总和的最准确方法是什么?

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:C++floatprecisionquestion我遇到了一个问题,即使用std::accumulate确定三种方法中最精确的方法来计算vector元素之和,vector元素之和只能是正数。1)doublesum(vector&v){returnaccumulate(v.begin(),v.end(),0.0);}2)doublesum(vector&v){sort(v.begin(),v.end());returnaccumulate(v.begin(),v.end(),0.0);}3)doublesum(

c++ - 在 std::pair 中存储不可复制(但可 move )的对象

我正在尝试将不可复制(但可move)的对象存储在std::pair中,如下所示:#includestructS{S();private:S(constS&);S&operator=(constS&);};intmain(){std::pairp{0,S()};return0;}但是我在使用gcc4.6时遇到以下编译器错误:Infileincludedfrominclude/c++/4.6.0/bits/move.h:53:0,frominclude/c++/4.6.0/bits/stl_pair.h:60,include/c++/4.6.0/utility:71,fromsrc/tes

c++ - 将数据序列化到 std::streambuf

我有一个VisualStudio2008C++项目,我在其中尝试将来自多个类的数据序列化为自定义std::streambuf实现。数据类及其序列化:structHeader{/*...*/};inlinestd::ostream&operatorstreambuffer实现提供缓冲的i/o并覆盖underflow和overflow。classMyStreamBuf:publicstd::streambuf{public:MyStreamBuf(){InitBuffers();};private:voidInitBuffers(){recv_buffer_.resize(buff_siz

c++ - Direct3D11(C++) : Rendering (basic) question

我一直在关注一本关于使用D3D11进行游戏编程的基础知识的书。我现在了解Direct3D的绝对基础知识:)但是……我有一个问题。在书中,我总是不得不一次制作一个演示。现在,我正在尝试用它制作2D游戏。因为我不想习惯坏习惯所以我需要你的建议。在书中,我总是必须定义一个(结构VertexPos与texcoord和位置成员)或(结构VertexPos只有一个XMFLOAT3位置成员)。在我制作的游戏中,我希望能够绘制没有纹理的实体表面和有纹理的表面。我不确定如何做到这一点,更不用说高效地做到这一点了。这是我的渲染函数:voidGameSpriteDemo::Render(){if(m_pD3

c++ - Direct3D11(C++) : Updating Texture coordinates in constant buffer?

我正在尝试使用Direct3D制作一个相当基本的2D引擎。我制作了一个LoadImage()函数,它将图像的所有相当静态的行为存储在一个对象中。(着色器、顶点缓冲区、采样器等)我计划在常量缓冲区中使用矩阵定位顶点。但是,我还想有一个DrawImage()函数,它有一个参数来告诉纹理的哪一部分应该被绘制(剪裁),所以我必须更新纹理坐标。由于顶点缓冲区已经预定义,我想知道是否有一种方法可以通过发送到顶点着色器的常量缓冲区来更新纹理坐标?我希望我的问题足够清楚,如果您有任何疑问,请查看下面的代码。boolGameManager::GMLoadImage(Image*pImage,constc